[INFO] cloning repository https://github.com/SpaceK33z/laser-dac-rs
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/SpaceK33z/laser-dac-rs" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FSpaceK33z%2Flaser-dac-rs", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FSpaceK33z%2Flaser-dac-rs'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 36b86557e7b3902d02f323044014a7a8e0ed12db
[INFO] testing SpaceK33z/laser-dac-rs against master#f9988fefd3add01f414f52b414308e7872622fee for pr-155114
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FSpaceK33z%2Flaser-dac-rs" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/SpaceK33z/laser-dac-rs
[INFO] removed 0 missing examples
[INFO] finished tweaking git repo https://github.com/SpaceK33z/laser-dac-rs
[INFO] tweaked toml for git repo https://github.com/SpaceK33z/laser-dac-rs written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/SpaceK33z/laser-dac-rs on toolchain f9988fefd3add01f414f52b414308e7872622fee
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/SpaceK33z/laser-dac-rs already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded zmij v1.0.10
[INFO] [stderr]   Downloaded asio-sys v0.2.6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 9d2efc39a528191aee3517073e5a145ecfe2f6570c508c0dcdf83eb94a62a260
[INFO] running `Command { std: "docker" "start" "-a" "9d2efc39a528191aee3517073e5a145ecfe2f6570c508c0dcdf83eb94a62a260", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "9d2efc39a528191aee3517073e5a145ecfe2f6570c508c0dcdf83eb94a62a260", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9d2efc39a528191aee3517073e5a145ecfe2f6570c508c0dcdf83eb94a62a260", kill_on_drop: false }`
[INFO] [stdout] 9d2efc39a528191aee3517073e5a145ecfe2f6570c508c0dcdf83eb94a62a260
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cbb28c75e6e06545321ae984cd604fde02c477c52ff2d4ca096c50783cdf2754
[INFO] running `Command { std: "docker" "start" "-a" "cbb28c75e6e06545321ae984cd604fde02c477c52ff2d4ca096c50783cdf2754", kill_on_drop: false }`
[INFO] [stderr]    Compiling cpal v0.15.3
[INFO] [stderr]    Compiling rusb v0.9.4
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling dasp_sample v0.11.0
[INFO] [stderr]    Compiling libc v0.2.178
[INFO] [stderr]    Compiling cc v1.2.49
[INFO] [stderr]    Compiling crossbeam-queue v0.3.12
[INFO] [stderr]    Compiling syn v2.0.111
[INFO] [stderr]    Compiling libusb1-sys v0.7.0
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling alsa v0.9.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling laser-dac v0.11.7 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 10.48s
[INFO] running `Command { std: "docker" "inspect" "cbb28c75e6e06545321ae984cd604fde02c477c52ff2d4ca096c50783cdf2754", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cbb28c75e6e06545321ae984cd604fde02c477c52ff2d4ca096c50783cdf2754", kill_on_drop: false }`
[INFO] [stdout] cbb28c75e6e06545321ae984cd604fde02c477c52ff2d4ca096c50783cdf2754
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] e304d355569442aa7ce8fd1c31c06a4f0d55b5481435522f982653a19e7ae619
[INFO] running `Command { std: "docker" "start" "-a" "e304d355569442aa7ce8fd1c31c06a4f0d55b5481435522f982653a19e7ae619", kill_on_drop: false }`
[INFO] [stderr]    Compiling memchr v2.7.6
[INFO] [stderr]    Compiling regex-syntax v0.8.8
[INFO] [stderr]    Compiling zmij v1.0.10
[INFO] [stderr]    Compiling nix v0.30.1
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]    Compiling serde_json v1.0.148
[INFO] [stderr]    Compiling clap_builder v4.5.53
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling jiff v0.2.17
[INFO] [stderr]    Compiling syn v2.0.111
[INFO] [stderr]    Compiling libusb1-sys v0.7.0
[INFO] [stderr]    Compiling idn-mock-server v0.1.0 (/opt/rustwide/workdir/tools/idn-mock-server)
[INFO] [stderr]    Compiling hound v3.5.1
[INFO] [stderr]    Compiling rusb v0.9.4
[INFO] [stderr]    Compiling alsa v0.9.1
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]    Compiling ctrlc v3.5.1
[INFO] [stderr]    Compiling cpal v0.15.3
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling laser-dac v0.11.7 (/opt/rustwide/workdir)
[INFO] [stderr]    Compiling clap v4.5.53
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]    Compiling env_filter v0.1.4
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 38.92s
[INFO] running `Command { std: "docker" "inspect" "e304d355569442aa7ce8fd1c31c06a4f0d55b5481435522f982653a19e7ae619", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e304d355569442aa7ce8fd1c31c06a4f0d55b5481435522f982653a19e7ae619", kill_on_drop: false }`
[INFO] [stdout] e304d355569442aa7ce8fd1c31c06a4f0d55b5481435522f982653a19e7ae619
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 12d6c974d4e9340d3268277282c139bb44e54be375ab8383c66bc912d793cec8
[INFO] running `Command { std: "docker" "start" "-a" "12d6c974d4e9340d3268277282c139bb44e54be375ab8383c66bc912d793cec8", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.22s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/laser_dac-d71e674055dbd087)
[INFO] [stdout] 
[INFO] [stdout] running 359 tests
[INFO] [stdout] test discovery::tests::discoverer_device_info_is_populated ... ok
[INFO] [stdout] test discovery::tests::discoverer_scan_is_called ... ok
[INFO] [stdout] test net_utils::tests::test_broadcast_address_slash_16 ... ok
[INFO] [stdout] test net_utils::tests::test_broadcast_address_slash_24 ... ok
[INFO] [stdout] test discovery::tests::slugify_collapses_whitespace_and_punctuation ... ok
[INFO] [stdout] test net_utils::tests::test_broadcast_address_slash_30 ... ok
[INFO] [stdout] test discovery::tests::discoverer_connect_dispatches_to_owning_registry ... ok
[INFO] [stdout] test presentation::tests::test_authored_frame_clone_shares_data ... ok
[INFO] [stdout] test presentation::tests::test_authored_frame_len ... ok
[INFO] [stdout] test presentation::tests::test_authored_frame_first_last_point ... ok
[INFO] [stdout] test presentation::tests::test_authored_frame_new_and_points ... ok
[INFO] [stdout] test presentation::tests::test_color_delay_line_resize_grow ... ok
[INFO] [stdout] test presentation::tests::test_color_delay_line_resize_shrink ... ok
[INFO] [stdout] test presentation::tests::test_authored_frame_from_vec ... ok
[INFO] [stdout] test presentation::tests::test_color_delay_line_resize_to_zero ... ok
[INFO] [stdout] test presentation::tests::test_color_delay_line_zero_delay_is_noop ... ok
[INFO] [stdout] test presentation::tests::test_color_delay_reset_clears_carry ... ok
[INFO] [stdout] test presentation::tests::test_compose_hardware_frame_content_not_cycled ... ok
[INFO] [stdout] test presentation::tests::test_compose_hardware_frame_a_to_b_no_cycling_artifact ... ok
[INFO] [stdout] test presentation::tests::test_compose_hardware_frame_natural_length_no_padding ... ok
[INFO] [stdout] test presentation::tests::test_color_delay_line_resize_same_is_noop ... ok
[INFO] [stdout] test presentation::tests::test_default_transition_always_blanks ... ok
[INFO] [stdout] test presentation::tests::test_engine_compose_hardware_frame_a_to_b_transition ... ok
[INFO] [stdout] test presentation::tests::test_default_transition_full_diagonal ... ok
[INFO] [stdout] test presentation::tests::test_default_transition_quintic_easing ... ok
[INFO] [stdout] test presentation::tests::test_engine_compose_hardware_frame_clamps_to_capacity ... ok
[INFO] [stdout] test presentation::tests::test_default_transition_same_point ... ok
[INFO] [stdout] test presentation::tests::test_engine_compose_hardware_frame_no_truncation_under_capacity ... ok
[INFO] [stdout] test presentation::tests::test_color_delay_line_carries_across_chunks ... ok
[INFO] [stdout] test presentation::tests::test_authored_frame_empty ... ok
[INFO] [stdout] test discovery::tests::info_eq_and_hash_use_only_stable_id ... ok
[INFO] [stdout] test presentation::tests::test_engine_compose_hardware_frame_empty_frame_produces_blanked_point ... ok
[INFO] [stdout] test presentation::tests::test_default_transition_scales_with_distance ... ok
[INFO] [stdout] test presentation::tests::test_default_transition_three_phase_structure ... ok
[INFO] [stdout] test presentation::tests::test_engine_compose_hardware_frame_self_loop_after_transition ... ok
[INFO] [stdout] test presentation::tests::test_engine_compose_hardware_frame_self_loop_clamps_to_capacity ... ok
[INFO] [stdout] test presentation::tests::test_compose_hardware_frame_short_frame_preserves_duty_cycle ... ok
[INFO] [stdout] test presentation::tests::test_default_transition_all_blanked ... ok
[INFO] [stdout] test presentation::tests::test_engine_compose_hardware_frame_self_loop_empty_produces_blanked_point ... ok
[INFO] [stdout] test presentation::tests::test_engine_compose_hardware_frame_promotes_pending ... ok
[INFO] [stdout] test presentation::tests::test_engine_compose_hardware_frame_skip ... ok
[INFO] [stdout] test presentation::tests::test_engine_compose_hardware_frame_transition_to_empty_produces_blanked_point ... ok
[INFO] [stdout] test presentation::tests::test_engine_empty_transition_result ... ok
[INFO] [stdout] test presentation::tests::test_engine_fill_chunk_cursor_continuity ... ok
[INFO] [stdout] test presentation::tests::test_engine_fill_chunk_cycles_frame ... ok
[INFO] [stdout] test presentation::tests::test_engine_fill_chunk_frame_change_inserts_transition ... ok
[INFO] [stdout] test presentation::tests::test_engine_fill_chunk_frame_skip ... ok
[INFO] [stdout] test presentation::tests::test_engine_fill_chunk_multiple_wraps_in_single_call ... ok
[INFO] [stdout] test presentation::tests::test_engine_fill_chunk_self_loop_with_transition ... ok
[INFO] [stdout] test presentation::tests::test_engine_reset_then_replay_frame ... ok
[INFO] [stdout] test presentation::tests::test_engine_set_pending_overwrites_existing_pending ... ok
[INFO] [stdout] test presentation::tests::test_engine_set_pending_promotes_when_no_current ... ok
[INFO] [stdout] test presentation::tests::test_fifo_a_to_b_coalesce_skips_incoming_first ... ok
[INFO] [stdout] test presentation::tests::test_fifo_a_to_c_skip_latest_coalesce ... ok
[INFO] [stdout] test presentation::tests::test_fifo_no_stale_self_loop_seam ... ok
[INFO] [stdout] test presentation::tests::test_default_transition_pps_scales_dwells ... ok
[INFO] [stdout] test presentation::tests::test_engine_compose_hardware_frame_self_loop ... ok
[INFO] [stdout] test presentation::tests::test_fifo_pending_at_seam_uses_latest ... ok
[INFO] [stdout] test presentation::tests::test_fifo_self_loop_coalesce_omits_last_point ... ok
[INFO] [stdout] test presentation::tests::test_fifo_self_loop_coalesce_single_point_preserved ... ok
[INFO] [stdout] test presentation::tests::test_fifo_stale_self_loop_discarded_across_chunks ... ok
[INFO] [stdout] test presentation::tests::test_frame_fifo_buffer_estimation_matches_shared_scheduler_helper ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_config_with_reconnect ... ok
[INFO] [stdout] test presentation::tests::test_engine_fill_chunk_promotes_pending_at_frame_end ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_fifo_metrics_advance_while_sleeping_with_healthy_buffer ... ok
[INFO] [stdout] test presentation::tests::test_engine_reset_clears_state ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_frame_swap_metrics_advance_while_waiting_for_readiness ... ok
[INFO] [stdout] test presentation::tests::test_color_delay_line_resize_from_zero ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_fifo_output_filter_not_rerun_for_inner_retry ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_frame_swap_output_filter_sees_post_clamp_cyclic_frame ... ok
[INFO] [stdout] test discovery::tests::registering_duplicate_prefix_panics - should panic ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_output_filter_resets_on_arm_and_disarm_and_sees_blanking ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_frame_swap_inflight_frame_stays_sticky_until_accepted ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_frame_swap_output_filter_not_rerun_for_retry ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_udp_timed_metrics_advance_while_retrying_same_chunk ... ok
[INFO] [stdout] test presentation::tests::test_frame_swap_a_to_b_coalesce ... ok
[INFO] [stdout] test presentation::tests::test_frame_swap_self_loop_coalesce ... ok
[INFO] [stdout] test presentation::tests::test_parity_a_to_b_with_coalesce ... ok
[INFO] [stdout] test presentation::tests::test_parity_a_to_b_with_transition ... ok
[INFO] [stdout] test presentation::tests::test_parity_a_to_c_skip ... ok
[INFO] [stdout] test presentation::tests::test_parity_self_loop_with_coalesce ... ok
[INFO] [stdout] test presentation::tests::test_parity_self_loop_with_transition ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_frame_swap_retries_same_inflight_frame_on_wouldblock ... ok
[INFO] [stdout] test protocols::avb::backend::tests::choose_stream_config_falls_back_to_max_rate ... ok
[INFO] [stdout] test protocols::avb::backend::tests::choose_stream_config_falls_back_when_default_rate_not_supported_with_required_channels ... ok
[INFO] [stdout] test protocols::avb::backend::tests::choose_stream_config_prefers_default_rate_when_supported ... ok
[INFO] [stdout] test protocols::avb::backend::tests::choose_stream_config_prefers_lowest_compatible_channel_count ... ok
[INFO] [stdout] test protocols::avb::backend::tests::choose_stream_config_returns_none_without_qualifying_channels ... ok
[INFO] [stdout] test protocols::avb::backend::tests::choose_stream_config_selects_5ch_when_lowest_qualifying ... ok
[INFO] [stdout] test protocols::avb::backend::tests::choose_stream_config_selects_valid_channels_and_rate_from_same_range ... ok
[INFO] [stdout] test protocols::avb::backend::tests::choose_stream_config_uses_default_rate_when_in_range ... ok
[INFO] [stdout] test protocols::avb::backend::tests::collect_candidates_filters_and_assigns_duplicate_indices ... ok
[INFO] [stdout] test protocols::avb::backend::tests::connect_and_open_use_same_stream_config_when_rate_changes_mid_connect ... ok
[INFO] [stdout] test presentation::tests::test_engine_before_first_frame_blanks_at_origin ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_arm_disarm ... ok
[INFO] [stdout] test protocols::avb::backend::tests::engine_at_96khz_uses_correct_queue_capacity_and_resampling ... ok
[INFO] [stdout] test protocols::avb::backend::tests::enqueue_resampled_checks_capacity ... ok
[INFO] [stdout] test protocols::avb::backend::tests::enqueue_resampled_interpolates_xy ... ok
[INFO] [stdout] test protocols::avb::backend::tests::enqueue_points_returns_would_block_when_capacity_exceeded ... ok
[INFO] [stdout] test discovery::tests::multiple_discoverers_with_distinct_prefixes ... ok
[INFO] [stdout] test presentation::tests::test_engine_compose_hardware_frame_empty_before_first_frame ... ok
[INFO] [stdout] test protocols::avb::backend::tests::fake_engine_open_failure_propagates_from_connect ... ok
[INFO] [stdout] test protocols::avb::backend::tests::fill_output_buffer_5ch_shutter_closed_blanks_rgb ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_fifo_submit_frame_writes_points ... ok
[INFO] [stdout] test protocols::avb::backend::tests::fill_output_buffer_open_shutter_writes_full_channels ... ok
[INFO] [stdout] test protocols::avb::backend::tests::fill_output_buffer_shutter_closed_blanks_rgbi_only ... ok
[INFO] [stdout] test protocols::avb::backend::tests::fill_output_buffer_underrun_outputs_zeroes ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_udp_timed_retries_same_transition_chunk_on_wouldblock ... ok
[INFO] [stdout] test protocols::avb::backend::tests::disconnect_completes_under_load ... ok
[INFO] [stdout] test protocols::avb::backend::tests::fill_output_buffer_5ch_underrun_holds_last_xy_blanked ... ok
[INFO] [stdout] test protocols::avb::backend::tests::stream_point_from_laser_point_clamps_and_scales ... ok
[INFO] [stdout] test protocols::avb::backend::tests::supports_required_channels_uses_default_fallback ... ok
[INFO] [stdout] test protocols::avb::backend::tests::reconnect_rebuilds_runtime_for_new_audio_sample_rate ... ok
[INFO] [stdout] test protocols::avb::backend::tests::fake_engine_connect_write_disconnect_end_to_end ... ok
[INFO] [stdout] test protocols::avb::backend::tests::fake_engine_5ch_connect_write_disconnect_end_to_end ... ok
[INFO] [stdout] test protocols::avb::backend::tests::try_write_points_passthrough_when_pps_matches_selected_audio_rate ... ok
[INFO] [stdout] test protocols::avb::backend::tests::underrun_holds_last_xy_blanked ... ok
[INFO] [stdout] test protocols::avb::backend::tests::try_write_points_resamples_down_to_selected_audio_rate ... ok
[INFO] [stdout] test protocols::avb::discovery::tests::format_stable_id_collapses_punctuation_and_case ... ok
[INFO] [stdout] test protocols::avb::discovery::tests::format_stable_id_slugs_name_and_appends_index ... ok
[INFO] [stdout] test protocols::avb::tests::blacklist_does_not_match_partial_or_unrelated ... ok
[INFO] [stdout] test protocols::avb::tests::blacklist_matches_exact_name_case_insensitively ... ok
[INFO] [stdout] test protocols::avb::backend::tests::try_write_points_resamples_up_to_selected_audio_rate ... ok
[INFO] [stdout] test protocols::ether_dream::discovery::tests::etherdream_stable_id_uses_mac ... ok
[INFO] [stdout] test protocols::ether_dream::protocol::tests::test_ether_dream_conversion_boundaries ... ok
[INFO] [stdout] test protocols::ether_dream::protocol::tests::test_ether_dream_conversion_clamps_out_of_range ... ok
[INFO] [stdout] test protocols::ether_dream::protocol::tests::test_ether_dream_conversion_center ... ok
[INFO] [stdout] test protocols::ether_dream::protocol::tests::test_ether_dream_coordinate_symmetry ... ok
[INFO] [stdout] test protocols::ether_dream::protocol::tests::test_ether_dream_conversion_infinity_clamps ... ok
[INFO] [stdout] test protocols::helios::backend::tests::fatal_usb_error_in_is_ready_marks_disconnected ... ok
[INFO] [stdout] test protocols::helios::backend::tests::fatal_usb_io_error_in_is_ready_marks_disconnected ... ok
[INFO] [stdout] test protocols::helios::backend::tests::fatal_usb_pipe_error_in_is_ready_marks_disconnected ... ok
[INFO] [stdout] test protocols::helios::backend::tests::map_err_device_not_opened_is_backend ... ok
[INFO] [stdout] test protocols::helios::backend::tests::map_err_usb_io_is_disconnected ... ok
[INFO] [stdout] test protocols::helios::backend::tests::map_err_usb_no_device_is_disconnected ... ok
[INFO] [stdout] test protocols::helios::backend::tests::map_err_usb_pipe_is_disconnected ... ok
[INFO] [stdout] test protocols::helios::backend::tests::map_err_usb_timeout_is_backend ... ok
[INFO] [stdout] test protocols::helios::backend::tests::mock_connected_and_ready ... ok
[INFO] [stdout] test protocols::helios::backend::tests::mock_write_frame_succeeds_when_connected ... ok
[INFO] [stdout] test protocols::helios::backend::tests::nonfatal_usb_error_in_is_ready_stays_connected ... ok
[INFO] [stdout] test protocols::helios::backend::tests::write_frame_returns_disconnected_on_fatal_usb_error ... ok
[INFO] [stdout] test protocols::helios::discovery::tests::format_stable_id_prefixes_hardware_name ... ok
[INFO] [stdout] test protocols::helios::frame::tests::test_helios_conversion_asymmetric ... ok
[INFO] [stdout] test protocols::helios::frame::tests::test_helios_conversion_boundaries ... ok
[INFO] [stdout] test protocols::helios::frame::tests::test_helios_conversion_center ... ok
[INFO] [stdout] test protocols::helios::frame::tests::test_helios_conversion_clamps_out_of_range ... ok
[INFO] [stdout] test protocols::helios::frame::tests::test_helios_conversion_infinity_clamps ... ok
[INFO] [stdout] test protocols::helios::frame::tests::test_helios_conversion_nan_does_not_panic ... ok
[INFO] [stdout] test protocols::helios::native::tests::test_adjusted_frame_params_applies_problem_size_workaround ... ok
[INFO] [stdout] test protocols::helios::frame::tests::test_helios_inversion_symmetry ... ok
[INFO] [stdout] test protocols::helios::native::tests::test_adjusted_frame_params_leaves_small_frames_unchanged ... ok
[INFO] [stdout] test protocols::helios::native::tests::test_bulk_transfer_timeout_matches_sdk ... ok
[INFO] [stdout] test protocols::helios::native::tests::test_encode_frame_truncates_problematic_transfer_payload ... ok
[INFO] [stdout] test protocols::idn::backend::tests::handle_worker_command_stop_replaces_backlog_with_blank ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::config_needed_on_first_frame ... ok
[INFO] [stdout] test protocols::idn::backend::tests::worker_loop_bursts_backlog_without_realtime_delay ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::config_needed_on_format_change ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::config_not_needed_for_periodic_refresh_only ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::content_id_construction ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::duration_calculation ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::max_points_per_packet_with_config ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::max_points_per_packet_without_config ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::point_format_descriptors_length ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::point_format_descriptors_not_empty ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::point_format_size_bytes ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::point_format_word_count ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::sequence_number_wrapping ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::service_data_match_wrapping ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::test_even_distribution_300_points ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::test_even_distribution_500_points ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::test_even_distribution_exact_max ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::test_even_distribution_small_frame ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::test_pad_points_nineteen ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::test_pad_points_pads_to_minimum ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::test_pad_points_single_point ... ok
[INFO] [stdout] test protocols::idn::dac::stream::tests::timestamp_truncation_to_u32 ... ok
[INFO] [stdout] test protocols::idn::dac::tests::test_is_excluded ... ok
[INFO] [stdout] test protocols::idn::discovery::tests::format_stable_id_uses_hostname ... ok
[INFO] [stdout] test protocols::idn::error::tests::test_sequence_mismatch_display ... ok
[INFO] [stdout] test protocols::idn::error::tests::test_sequence_mismatch_equality ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_group_request_byte_layout ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_group_request_get_constructor ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_group_request_roundtrip ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_group_request_set_with_auth ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_group_request_set_constructor ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_group_request_size ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_group_response_byte_layout ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_group_response_enabled_groups ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_group_response_is_success ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_group_response_is_group_enabled ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_group_response_roundtrip ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_group_response_size ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_idn_conversion_center ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_idn_conversion_clamps_out_of_range ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_idn_conversion_half_values ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_idn_conversion_infinity_clamps ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_idn_conversion_min ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_idn_conversion_max ... ok
[INFO] [stdout] test protocols::idn::protocol::tests::test_idn_coordinate_symmetry ... ok
[INFO] [stdout] test protocols::lasercube_usb::discovery::tests::format_stable_id_falls_back_to_usb_address ... ok
[INFO] [stdout] test protocols::lasercube_usb::protocol::tests::test_sample_blank ... ok
[INFO] [stdout] test protocols::lasercube_usb::discovery::tests::format_stable_id_prefers_serial_when_present ... ok
[INFO] [stdout] test protocols::lasercube_usb::protocol::tests::test_sample_clamps_coordinates ... ok
[INFO] [stdout] test protocols::lasercube_usb::protocol::tests::test_sample_flip ... ok
[INFO] [stdout] test protocols::lasercube_usb::protocol::tests::test_sample_size ... ok
[INFO] [stdout] test protocols::lasercube_usb::protocol::tests::test_sample_new ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::ack_correlates_to_send_time ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::ack_only_updates_sent_track_if_newer ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::ack_track_can_dominate ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::ack_track_decays_over_time ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::ack_updates_fullness ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::can_send_after_drain ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::can_send_when_empty ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::cannot_send_when_full ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::fullness_decays_over_time ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::fullness_never_goes_negative ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::new_estimator_has_zero_fullness ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::multiple_sends_accumulate ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::rate_decrease_reduces_writable_headroom ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::recent_entries_kept ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::reset_clears_state ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::returns_max_of_both_tracks ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::send_fullness_is_clamped_to_capacity ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::send_increases_fullness ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::set_point_rate_changes_decay ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::stale_entries_removed ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::unknown_message_still_updates_ack_track ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::wrapping_message_numbers ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::zero_rate_no_decay ... ok
[INFO] [stdout] test protocols::lasercube_wifi::dac::buffer_estimator::tests::zero_rate_no_panic ... ok
[INFO] [stdout] test protocols::lasercube_wifi::discovery::tests::format_stable_id_handles_ipv6 ... ok
[INFO] [stdout] test protocols::lasercube_wifi::discovery::tests::format_stable_id_uses_ip ... ok
[INFO] [stdout] test protocols::lasercube_wifi::tests::caps_from_discovery_derive_from_device_buffer ... ok
[INFO] [stdout] test protocols::lasercube_wifi::tests::default_caps_are_network_fifo_with_safety_margin ... ok
[INFO] [stdout] test protocols::lasercube_wifi::tests::test_blank_point ... ok
[INFO] [stdout] test protocols::lasercube_wifi::tests::test_point_signed_conversion ... ok
[INFO] [stdout] test resample::tests::catmull_rom_midpoint_on_linear_data ... ok
[INFO] [stdout] test protocols::oscilloscope::discovery::tests::format_stable_id_slugs_device_name ... ok
[INFO] [stdout] test resample::tests::catmull_rom_passes_through_knots ... ok
[INFO] [stdout] test resample::tests::catmull_rom_with_clamped_boundaries ... ok
[INFO] [stdout] test resample::tests::resampled_len_passthrough ... ok
[INFO] [stdout] test resample::tests::resampled_len_downsample ... ok
[INFO] [stdout] test resample::tests::resampled_len_upsample ... ok
[INFO] [stdout] test scheduler::tests::advance_scheduled_ahead_accumulates_fractional_consumption ... ok
[INFO] [stdout] test scheduler::tests::conservative_buffered_points_prefers_lower_estimate ... ok
[INFO] [stdout] test stream::tests::test_arm_disarm_arm_cycle ... ok
[INFO] [stdout] test stream::tests::test_arm_opens_shutter_disarm_closes_shutter ... ok
[INFO] [stdout] test stream::tests::test_backend_write_error_exits_with_disconnected ... ok
[INFO] [stdout] test stream::tests::test_backend_write_error_fires_on_error ... ok
[INFO] [stdout] test stream::tests::test_backend_write_error_immediate_fail ... ok
[INFO] [stdout] test stream::tests::test_build_fill_request_calculates_min_and_target_points ... ok
[INFO] [stdout] test stream::tests::test_build_fill_request_ceiling_rounds_min_points ... ok
[INFO] [stdout] test stream::tests::test_build_fill_request_uses_conservative_estimation ... ok
[INFO] [stdout] test stream::tests::test_color_delay_dynamic_change ... ok
[INFO] [stdout] test stream::tests::test_color_delay_resets_on_disarm_arm ... ok
[INFO] [stdout] test stream::tests::test_color_delay_shifts_colors ... ok
[INFO] [stdout] test stream::tests::test_color_delay_zero_is_passthrough ... ok
[INFO] [stdout] test stream::tests::test_dac_new_has_no_reconnect_target ... ok
[INFO] [stdout] test stream::tests::test_device_start_stream_connects_backend ... ok
[INFO] [stdout] test stream::tests::test_device_start_stream_keeps_explicit_network_buffer_settings ... ok
[INFO] [stdout] test stream::tests::test_device_start_stream_keeps_usb_defaults ... ok
[INFO] [stdout] test protocols::avb::backend::tests::callback_progresses_under_producer_contention ... ok
[INFO] [stdout] test stream::tests::test_device_start_stream_promotes_untouched_defaults_for_network_backends ... ok
[INFO] [stdout] test stream::tests::test_device_start_stream_rejects_frame_swap_backend ... ok
[INFO] [stdout] test stream::tests::test_disarm_parks_scanners_at_configured_park_position ... ok
[INFO] [stdout] test stream::tests::test_disarm_parks_scanners_at_origin_default_policy ... ok
[INFO] [stdout] test stream::tests::test_disarm_repeat_last_falls_back_to_blank ... ok
[INFO] [stdout] test stream::tests::test_disarm_underrun_respects_park_policy ... ok
[INFO] [stdout] test stream::tests::test_estimate_buffer_conservative_prevents_underrun ... ok
[INFO] [stdout] test stream::tests::test_estimate_buffer_uses_min_of_hardware_and_software ... ok
[INFO] [stdout] test stream::tests::test_estimate_buffer_uses_software_when_no_hardware ... ok
[INFO] [stdout] test stream::tests::test_fill_result_end_closes_shutter ... ok
[INFO] [stdout] test stream::tests::test_fill_result_end_drains_with_queue_depth ... ok
[INFO] [stdout] test stream::tests::test_fill_result_end_drains_without_queue_depth ... ok
[INFO] [stdout] test stream::tests::test_fill_result_end_returns_producer_ended ... ok
[INFO] [stdout] test stream::tests::test_fill_result_end_skips_drain_with_zero_timeout ... ok
[INFO] [stdout] test protocols::avb::backend::tests::wouldblock_then_recover_after_callback_drains ... ok
[INFO] [stdout] test protocols::avb::backend::tests::queue_capacity_scales_with_audio_sample_rate ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_start_frame_session_rejects_invalid_pps_with_reconnect ... ok
[INFO] [stdout] test stream::tests::test_fill_result_end_respects_drain_timeout ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_frame_swap_writes_frames ... FAILED
[INFO] [stdout] test protocols::avb::backend::tests::fill_output_buffer_5ch_open_shutter_writes_xyrgb_no_intensity ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_metrics_available_and_disconnect_after_stop ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_stop ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_fifo_output_filter_skips_keepalives_and_sees_color_delay ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_metrics_write_success_only_advances_on_successful_write ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_output_filter_resets_on_reconnect_and_replays_last_frame ... ok
[INFO] [stdout] test protocols::ether_dream::protocol::tests::test_ether_dream_color_direct_passthrough ... ok
[INFO] [stdout] test stream::tests::test_fill_result_starved_with_stop_policy ... ok
[INFO] [stdout] test stream::tests::test_handle_underrun_advances_state ... ok
[INFO] [stdout] test stream::tests::test_handle_underrun_blanks_when_disarmed ... ok
[INFO] [stdout] test stream::tests::test_helios_immediate_status_timeout ... ok
[INFO] [stdout] test stream::tests::test_helios_status_timeout_exits_with_disconnected ... ok
[INFO] [stdout] test stream::tests::test_into_dac_preserves_reconnect_target ... ok
[INFO] [stdout] test stream::tests::test_helios_status_timeout_fires_on_error_with_backend_variant ... ok
[INFO] [stdout] test stream::tests::test_into_dac_preserves_target_without_reconnect ... ok
[INFO] [stdout] test stream::tests::test_network_fifo_accumulates_scheduled_ahead ... ok
[INFO] [stdout] test stream::tests::test_network_fifo_lasercube_default_target_requests_topup ... ok
[INFO] [stdout] test stream::tests::test_network_fifo_lasercube_large_target_uses_more_capacity ... ok
[INFO] [stdout] test stream::tests::test_reset_state_for_reconnect_resizes_buffers ... ok
[INFO] [stdout] test stream::tests::test_reset_state_for_reconnect_clears_timing ... ok
[INFO] [stdout] test stream::tests::test_full_stream_lifecycle_external_stop ... ok
[INFO] [stdout] test presentation::tests::test_frame_session_metrics_advance_during_reconnect_backoff ... ok
[INFO] [stdout] test stream::tests::test_run_buffer_driven_behavior ... ok
[INFO] [stdout] test stream::tests::test_run_sleeps_when_buffer_healthy ... ok
[INFO] [stdout] test protocols::avb::backend::tests::queue_bound_invariant_under_stress ... ok
[INFO] [stdout] test stream::tests::test_run_stops_on_control_stop ... ok
[INFO] [stdout] test stream::tests::test_sleep_with_stop_exits_on_stop ... ok
[INFO] [stdout] test stream::tests::test_start_stream_reconnect_with_target_succeeds ... ok
[INFO] [stdout] test stream::tests::test_start_stream_reconnect_without_target_errors ... ok
[INFO] [stdout] test stream::tests::test_start_stream_with_reconnect_rejects_invalid_pps ... ok
[INFO] [stdout] test stream::tests::test_startup_blank_blanks_first_n_points ... ok
[INFO] [stdout] test stream::tests::test_startup_blank_resets_on_rearm ... ok
[INFO] [stdout] test stream::tests::test_startup_blank_zero_is_noop ... ok
[INFO] [stdout] test stream::tests::test_stop_closes_shutter ... ok
[INFO] [stdout] test stream::tests::test_stream_control_arm_disarm ... ok
[INFO] [stdout] test stream::tests::test_stream_control_clone_shares_state ... ok
[INFO] [stdout] test stream::tests::test_stream_control_stop ... ok
[INFO] [stdout] test stream::tests::test_stream_disarm_during_streaming ... ok
[INFO] [stdout] test stream::tests::reconnect_rediscovers_custom_backend_via_factory ... ok
[INFO] [stdout] test stream::tests::test_stream_with_mock_backend_disconnect ... ok
[INFO] [stdout] test stream::tests::test_udp_timed_build_fill_request_uses_full_packet ... ok
[INFO] [stdout] test stream::tests::test_udp_timed_prefills_to_max_points_per_chunk ... ok
[INFO] [stdout] test stream::tests::test_udp_timed_sleep_slice_caps_coarse_sleep ... ok
[INFO] [stdout] test stream::tests::test_udp_timed_sleep_slice_switches_to_busy_wait_near_deadline ... ok
[INFO] [stdout] test stream::tests::test_udp_timed_uses_max_points_per_chunk_for_lead ... ok
[INFO] [stdout] test stream::tests::test_validate_config_avb_accepts_standard_pps ... ok
[INFO] [stdout] test stream::tests::test_validate_config_rejects_pps_above_max ... ok
[INFO] [stdout] test stream::tests::test_validate_config_rejects_pps_below_min ... ok
[INFO] [stdout] test stream::tests::with_discovery_factory_creates_target_when_none ... ok
[INFO] [stdout] test stream::tests::with_discovery_factory_enables_reconnect_for_frame_session ... ok
[INFO] [stdout] test stream::tests::with_discovery_factory_replaces_factory_on_existing_target ... ok
[INFO] [stdout] test types::tests::test_dac_connection_state_equality ... ok
[INFO] [stdout] test types::tests::test_dac_type_all_returns_all_builtin_types ... ok
[INFO] [stdout] test types::tests::test_dac_type_can_be_used_in_hashset ... ok
[INFO] [stdout] test types::tests::test_dac_type_display_uses_display_name ... ok
[INFO] [stdout] test types::tests::test_enabled_dac_types_all_enables_everything ... ok
[INFO] [stdout] test types::tests::test_enabled_dac_types_chaining ... ok
[INFO] [stdout] test types::tests::test_enabled_dac_types_default_enables_all ... ok
[INFO] [stdout] test types::tests::test_enabled_dac_types_enable_disable_toggles_correctly ... ok
[INFO] [stdout] test types::tests::test_enabled_dac_types_idempotent_operations ... ok
[INFO] [stdout] test types::tests::test_enabled_dac_types_iter_only_returns_enabled ... ok
[INFO] [stdout] test types::tests::test_enabled_dac_types_none_disables_everything ... ok
[INFO] [stdout] test types::tests::test_laser_point_blanked_sets_all_colors_to_zero ... ok
[INFO] [stdout] test stream::tests::test_fractional_consumed_prevents_stall ... ok
[INFO] [stdout] test stream::tests::test_fill_result_filled_updates_last_chunk_when_armed ... ok
[INFO] [stdout] test stream::tests::test_fill_result_filled_exceeds_buffer_clamped ... ok
[INFO] [stdout] test stream::tests::test_fill_result_filled_writes_points_and_updates_state ... ok
[INFO] [stdout] test stream::tests::test_fill_result_starved_repeat_last_with_stored_chunk ... ok
[INFO] [stdout] test stream::tests::test_fill_result_starved_repeat_last_without_stored_chunk_falls_back_to_blank ... ok
[INFO] [stdout] test stream::tests::test_fill_result_starved_with_park_policy ... ok
[INFO] [stdout] test stream::tests::test_full_stream_lifecycle_into_dac_recovery ... ok
[INFO] [stdout] test stream::tests::test_full_stream_lifecycle_with_idle_policy_recovery ... ok
[INFO] [stdout] test stream::tests::test_full_stream_lifecycle_create_arm_stream_stop ... ok
[INFO] [stdout] test stream::tests::test_run_filled_zero_with_target_treated_as_starved ... ok
[INFO] [stdout] test stream::tests::test_run_producer_ended ... ok
[INFO] [stdout] test stream::tests::test_run_retries_on_would_block ... ok
[INFO] [stdout] test stream::tests::test_run_starved_applies_underrun_policy ... ok
[INFO] [stdout] test stream::tests::test_stream_stats_tracking ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- presentation::tests::test_frame_session_frame_swap_writes_frames stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'presentation::tests::test_frame_session_frame_swap_writes_frames' (105) panicked at src/presentation/tests.rs:2049:5:
[INFO] [stdout] Should have written frames
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x60d6a7f468fa - std[1209cfb42f6d497f]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x60d6a7f468fa - std[1209cfb42f6d497f]::backtrace_rs::backtrace::trace_unsynchronized::<std[1209cfb42f6d497f]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x60d6a7f468fa - std[1209cfb42f6d497f]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x60d6a7f468fa - <<std[1209cfb42f6d497f]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[4a92201981c6b77a]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x60d6a7f5cdba - <core[4a92201981c6b77a]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x60d6a7f5cdba - core[4a92201981c6b77a]::fmt::write
[INFO] [stdout]    6:     0x60d6a7f4b782 - std[1209cfb42f6d497f]::io::default_write_fmt::<alloc[420bb310a727dfd7]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/io/mod.rs:621:11
[INFO] [stdout]    7:     0x60d6a7f4b782 - <alloc[420bb310a727dfd7]::vec::Vec<u8> as std[1209cfb42f6d497f]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/io/mod.rs:1976:13
[INFO] [stdout]    8:     0x60d6a7f2482f - <std[1209cfb42f6d497f]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x60d6a7f2482f - std[1209cfb42f6d497f]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x60d6a7f3e8e9 - std[1209cfb42f6d497f]::panicking::default_hook
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x60d6a7eb0adc - <alloc[420bb310a727dfd7]::boxed::Box<dyn for<'a, 'b> core[4a92201981c6b77a]::ops::function::Fn<(&'a std[1209cfb42f6d497f]::panic::PanicHookInfo<'b>,), Output = ()> + core[4a92201981c6b77a]::marker::Sync + core[4a92201981c6b77a]::marker::Send> as core[4a92201981c6b77a]::ops::function::Fn<(&std[1209cfb42f6d497f]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/alloc/src/boxed.rs:2285:9
[INFO] [stdout]   12:     0x60d6a7eb0adc - test[59e67a9bc0e119f1]::test_main_inner::<test[59e67a9bc0e119f1]::test_main_static::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/test/src/lib.rs:155:21
[INFO] [stdout]   13:     0x60d6a7f3eaa2 - <alloc[420bb310a727dfd7]::boxed::Box<dyn for<'a, 'b> core[4a92201981c6b77a]::ops::function::Fn<(&'a std[1209cfb42f6d497f]::panic::PanicHookInfo<'b>,), Output = ()> + core[4a92201981c6b77a]::marker::Sync + core[4a92201981c6b77a]::marker::Send> as core[4a92201981c6b77a]::ops::function::Fn<(&std[1209cfb42f6d497f]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/alloc/src/boxed.rs:2285:9
[INFO] [stdout]   14:     0x60d6a7f3eaa2 - std[1209cfb42f6d497f]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x60d6a7f2491a - std[1209cfb42f6d497f]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x60d6a7f19a49 - std[1209cfb42f6d497f]::sys::backtrace::__rust_end_short_backtrace::<std[1209cfb42f6d497f]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x60d6a7f257bd - __rustc[4effac393e9f3da6]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x60d6a7f5d57c - core[4a92201981c6b77a]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x60d6a7d1d22f - laser_dac[a4603acbe9f6cae4]::presentation::tests::test_frame_session_frame_swap_writes_frames
[INFO] [stdout]                                at /opt/rustwide/workdir/src/presentation/tests.rs:2049:5
[INFO] [stdout]   20:     0x60d6a7d07fe7 - laser_dac[a4603acbe9f6cae4]::presentation::tests::test_frame_session_frame_swap_writes_frames::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/presentation/tests.rs:2032:49
[INFO] [stdout]   21:     0x60d6a7dd7756 - <laser_dac[a4603acbe9f6cae4]::presentation::tests::test_frame_session_frame_swap_writes_frames::{closure#0} as core[4a92201981c6b77a]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   22:     0x60d6a7ea3dbb - <fn() -> core[4a92201981c6b77a]::result::Result<(), alloc[420bb310a727dfd7]::string::String> as core[4a92201981c6b77a]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x60d6a7ea3dbb - test[59e67a9bc0e119f1]::__rust_begin_short_backtrace::<core[4a92201981c6b77a]::result::Result<(), alloc[420bb310a727dfd7]::string::String>, fn() -> core[4a92201981c6b77a]::result::Result<(), alloc[420bb310a727dfd7]::string::String>>
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/test/src/lib.rs:724:18
[INFO] [stdout]   24:     0x60d6a7eb15ab - test[59e67a9bc0e119f1]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/test/src/lib.rs:747:74
[INFO] [stdout]   25:     0x60d6a7eb15ab - <core[4a92201981c6b77a]::panic::unwind_safe::AssertUnwindSafe<test[59e67a9bc0e119f1]::run_test_in_process::{closure#0}> as core[4a92201981c6b77a]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   26:     0x60d6a7eb15ab - std[1209cfb42f6d497f]::panicking::catch_unwind::do_call::<core[4a92201981c6b77a]::panic::unwind_safe::AssertUnwindSafe<test[59e67a9bc0e119f1]::run_test_in_process::{closure#0}>, core[4a92201981c6b77a]::result::Result<(), alloc[420bb310a727dfd7]::string::String>>
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/panicking.rs:581:40
[INFO] [stdout]   27:     0x60d6a7eb15ab - std[1209cfb42f6d497f]::panicking::catch_unwind::<core[4a92201981c6b77a]::result::Result<(), alloc[420bb310a727dfd7]::string::String>, core[4a92201981c6b77a]::panic::unwind_safe::AssertUnwindSafe<test[59e67a9bc0e119f1]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/panicking.rs:544:19
[INFO] [stdout]   28:     0x60d6a7eb15ab - std[1209cfb42f6d497f]::panic::catch_unwind::<core[4a92201981c6b77a]::panic::unwind_safe::AssertUnwindSafe<test[59e67a9bc0e119f1]::run_test_in_process::{closure#0}>, core[4a92201981c6b77a]::result::Result<(), alloc[420bb310a727dfd7]::string::String>>
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/panic.rs:359:14
[INFO] [stdout]   29:     0x60d6a7eb15ab - test[59e67a9bc0e119f1]::run_test_in_process
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/test/src/lib.rs:747:27
[INFO] [stdout]   30:     0x60d6a7eb15ab - test[59e67a9bc0e119f1]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/test/src/lib.rs:668:43
[INFO] [stdout]   31:     0x60d6a7eaacc4 - test[59e67a9bc0e119f1]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/test/src/lib.rs:698:41
[INFO] [stdout]   32:     0x60d6a7eaacc4 - std[1209cfb42f6d497f]::sys::backtrace::__rust_begin_short_backtrace::<test[59e67a9bc0e119f1]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   33:     0x60d6a7eb41b2 - std[1209cfb42f6d497f]::thread::lifecycle::spawn_unchecked::<test[59e67a9bc0e119f1]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/thread/lifecycle.rs:70:13
[INFO] [stdout]   34:     0x60d6a7eb41b2 - <core[4a92201981c6b77a]::panic::unwind_safe::AssertUnwindSafe<std[1209cfb42f6d497f]::thread::lifecycle::spawn_unchecked<test[59e67a9bc0e119f1]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[4a92201981c6b77a]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   35:     0x60d6a7eb41b2 - std[1209cfb42f6d497f]::panicking::catch_unwind::do_call::<core[4a92201981c6b77a]::panic::unwind_safe::AssertUnwindSafe<std[1209cfb42f6d497f]::thread::lifecycle::spawn_unchecked<test[59e67a9bc0e119f1]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/panicking.rs:581:40
[INFO] [stdout]   36:     0x60d6a7eb41b2 - std[1209cfb42f6d497f]::panicking::catch_unwind::<(), core[4a92201981c6b77a]::panic::unwind_safe::AssertUnwindSafe<std[1209cfb42f6d497f]::thread::lifecycle::spawn_unchecked<test[59e67a9bc0e119f1]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/panicking.rs:544:19
[INFO] [stdout]   37:     0x60d6a7eb41b2 - std[1209cfb42f6d497f]::panic::catch_unwind::<core[4a92201981c6b77a]::panic::unwind_safe::AssertUnwindSafe<std[1209cfb42f6d497f]::thread::lifecycle::spawn_unchecked<test[59e67a9bc0e119f1]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/panic.rs:359:14
[INFO] [stdout]   38:     0x60d6a7eb41b2 - std[1209cfb42f6d497f]::thread::lifecycle::spawn_unchecked::<test[59e67a9bc0e119f1]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/thread/lifecycle.rs:68:26
[INFO] [stdout]   39:     0x60d6a7eb41b2 - <std[1209cfb42f6d497f]::thread::lifecycle::spawn_unchecked<test[59e67a9bc0e119f1]::run_test::{closure#1}, ()>::{closure#1} as core[4a92201981c6b77a]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   40:     0x60d6a7f45e5f - <alloc[420bb310a727dfd7]::boxed::Box<dyn core[4a92201981c6b77a]::ops::function::FnOnce<(), Output = ()> + core[4a92201981c6b77a]::marker::Send> as core[4a92201981c6b77a]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/alloc/src/boxed.rs:2271:9
[INFO] [stdout]   41:     0x60d6a7f45e5f - <std[1209cfb42f6d497f]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/f9988fefd3add01f414f52b414308e7872622fee/library/std/src/sys/thread/unix.rs:118:17
[INFO] [stdout]   42:     0x765ef0139aa4 - <unknown>
[INFO] [stdout]   43:     0x765ef01c6a64 - clone
[INFO] [stdout]   44:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     presentation::tests::test_frame_session_frame_swap_writes_frames
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 358 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.57s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] running `Command { std: "docker" "inspect" "12d6c974d4e9340d3268277282c139bb44e54be375ab8383c66bc912d793cec8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "12d6c974d4e9340d3268277282c139bb44e54be375ab8383c66bc912d793cec8", kill_on_drop: false }`
[INFO] [stdout] 12d6c974d4e9340d3268277282c139bb44e54be375ab8383c66bc912d793cec8
